import babelpolyfill from 'babel-polyfill'
import Vue from 'vue'
import App from './App'
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
//import './assets/theme/theme-green/index.css'
import VueRouter from 'vue-router'
import store from './vuex/store'
import Vuex from 'vuex'
//import NProgress from 'nprogress'
//import 'nprogress/nprogress.css'
import routes from './routes'
//import Mock from './mock'
//Mock.bootstrap();
import 'font-awesome/css/font-awesome.min.css'

import axios from "axios";
import '@/common/js/permission'
axios.defaults.baseURL="http://localhost:8080/"
Vue.prototype.$http = axios;

Vue.use(ElementUI)
Vue.use(VueRouter)
Vue.use(Vuex)

//NProgress.configure({ showSpinner: false });

const router = new VueRouter({
  routes
})

/*router.beforeEach((to, from, next) => {

  //NProgress.start();
  if (to.path == '/login') {
    sessionStorage.removeItem('user');
  }
  let user = JSON.parse(sessionStorage.getItem('user'));

  if (!user && to.path != '/login') {
    next({ path: '/login' })
  } else {
    alert(777)
    next()
  }
})*/

//router.afterEach(transition => {
//NProgress.done();
//});
axios.interceptors.request.use(res=>{
  let token = localStorage.getItem("U-TOKEN");
  if(token){
    res.headers["token"] = token;
  }
  return res;
},error => {
  Promise.reject(error)
})
axios.interceptors.response.use(res => {
  //后端响应的是没有登录的信息
  if (false === res.data.success && "noLogin" === res.data.message) {
    localStorage.removeItem("token");
    localStorage.removeItem("logininfo");
    router.push({path: '/login'});
  }
  if (false === res.data.success && "noPermission" === res.data.message) {
    //this.$message.warning("没有权限请联系管理员");
    alert("没有权限请联系管理员")
  }
  if (false === res.data.success && "timeOut" === res.data.message) {

    //this.$message.warning("没有权限请联系管理员");
    localStorage.removeItem("token");
    localStorage.removeItem("logininfo");
    alert("登录过期")
    router.push({path: '/login'});
  }
  return res;
},error => {
  Promise.reject(error)
})
router.beforeEach((to, from, next) => {
  if (to.path == '/login' || to.path == "/user/PhoneRegister") {
    localStorage.removeItem("U-TOKEN");
    localStorage.removeItem("logininfo");
    next();//放行
  }else{
    let logininfo = localStorage.getItem('logininfo');
    if (logininfo) {
      next();
    } else {
      next({path: '/login'});//跳转到login
    }
  }
})
initIndexRouters();
function initIndexRouters(){
  if(!localStorage.menus){
    return;
  }
  //防止重复配置路由：5就是main.js中路由的个数 - 如果你的静态路由是6个这里要写成6
  if(router.options.routes.length>5){
    return;
  }
  let menus = localStorage.getItem('menus');
  menus = JSON.parse(menus);//对象
  let tempRouters = [];
  menus.forEach(menu=>{
    let indexRouter = {
      path: '/',
      iconCls: menu.icon,
      name: menu.name,
      component: resolve => require(['@/views/Home'], resolve),
      children: []
    }
    menu.children.forEach(cMenu=>{
      let cr = {
        path: cMenu.url,
        name: cMenu.name,
        component: resolve => require(['@/views/'+cMenu.component], resolve)
      }
      indexRouter.children.push(cr)
    })
    tempRouters.push(indexRouter)
    router.options.routes.push(indexRouter)
  })
  //动态路由配置
  router.addRoutes(tempRouters);
}
new Vue({
  //el: '#app',
  //template: '<App/>',
  router,
  store,
  //components: { App }
  render: h => h(App)
}).$mount('#app')

